<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
    </head>

    <body>
        <p>事件循环</p>
        <div>
            <p>script start </p>
            <p>async1 start </p>
            <p>async2 </p>
            <p>promise1 </p>
            <p>script end </p>
            <p>async1 end </p>
            <p>promise2 </p>
            <p>setTimeout</div></p>
        <div>
            知识点： 考察的是事件循环和回调队列。注意以下几点： Promise 优先于 setTimeout 宏任务，所以 setTimeout 回调会最后执行 Promise 一旦被定义就会立即执行 Promise 的 resolve 和 reject
            是异步执行的回调。所以 resolve() 会被放到回调队列中，在主函数执行完和 setTimeout 之前调用 await 执行完后，会让出线程。async 标记的函数会返回一个 Promise 对象
        </div>
        <div>
            解析： 首先，事件循环从宏任务（macrostack）队列开始，这个时候，宏任务队列中，只有一个 script (整体代码)任务。从宏任务队列中取出一个任务来执行。 首先执行 console.log('script start')，输出
            ‘script start' 遇到 setTimeout 把 console.log('setTimeout') 放到 macrotask 队列中 执行 aync1() 输出 ‘async1 start' 和 'async2' ,把 console.log('async1 end') 放到 micro 队列中 执行到
            promise ，输出 'promise1' ，把 console.log('promise2') 放到 micro 队列中 执行 console.log('script end')，输出 ‘script end' macrotask 执行完成会执行 microtask ，把 microtask quene 里面的
            microtask 全部拿出来一次性执行完，所以会输出 'async1 end' 和 ‘promise2' 开始新一轮的事件循环，去除执行一个 macrotask 执行，所以会输出 ‘setTimeout'
        </div>
        版权声明：本文为CSDN博主「墨语轩」的原创文章，遵循CC 4.0 BY-SA版权协议，转载请附上原文出处链接及本声明。 原文链接：https://blog.csdn.net/MFWSCQ/article/details/105109727
        <script>
            async function async1() {
                console.log('async1 start');
                await async2();
                console.log('async1 end');
            }

            async function async2() {
                console.log('async2');
            }

            console.log('script start');

            setTimeout(() => {
                console.log('setTimeout');
            }, 0);

            async1();

            new Promise((resolve) => {
                console.log('promise1');
                resolve();
            }).then(() => {
                console.log('promise2');
            });

            console.log('script end');
            // script start
            // async1 start
            // async2
            // promise1
            // script end
            // async1 end
            // promise2
            // setTimeout
            // ————————————————
            // 版权声明：本文为CSDN博主「墨语轩」的原创文章，遵循CC 4.0 BY-SA版权协议，转载请附上原文出处链接及本声明。
            // 原文链接：https://blog.csdn.net/MFWSCQ/article/details/105109727
        </script>
    </body>
</html>
